React is an easy to use framework for building front end apps.
NativeScript is a mobile app framework that lets us build native mobile apps with popular front end frameworks.
In this article, we’ll look at how to build an app with NativeScript React.
HtmlView
We can add the HtmlView
component to display static HTML content.
For instance, we can write:
import * as React from "react";
export default function Greeting({ }) {
return (
<frame>
<page>
<actionBar title="Default Page Title" />
<flexboxLayout justifyContent='center' >
<htmlView html="<div><h1>hello world</h1></div>" />
</flexboxLayout>
</page>
</frame>
);
}
We set the html
prop to the HTML string we want to render.
Then it’ll be displayed in our app.
Image
We can display images with the image
component.
For instance, we can write:
import * as React from "react";
export default function Greeting({ }) {
return (
<frame>
<page>
<actionBar title="Default Page Title" />
<flexboxLayout justifyContent='center' >
<image src="~/assets/pic.jpg" stretch="none" />
</flexboxLayout>
</page>
</frame>
);
}
Then we display the pic.jpg
image in the /src/assets
folder.
We can display an image from a URL.
To do this, we write:
import * as React from "react";
export default function Greeting({ }) {
return (
<frame>
<page>
<actionBar title="Default Page Title" />
<flexboxLayout justifyContent='center' >
<image src="https://i.picsum.photos/id/20/200/200.jpg?hmac=wHmtG3BEC6aOsGZU_Q2wnxVQq34B__t4x4LFw-sptM8" stretch="none" />
</flexboxLayout>
</page>
</frame>
);
}
to set the src
prop to the URL of an image.
Also, we can display an icon by writing:
import * as React from "react";
export default function Greeting({ }) {
return (
<frame>
<page>
<actionBar title="Default Page Title" />
<flexboxLayout justifyContent='center' >
<image src="res://icon" stretch="none" />
</flexboxLayout>
</page>
</frame>
);
}
We can also display an base64 image string by writing:
import * as React from "react";
export default function Greeting({ }) {
return (
<frame>
<page>
<actionBar title="Default Page Title" />
<flexboxLayout justifyContent='center' >
<image src="" stretch="none" />
</flexboxLayout>
</page>
</frame>
);
}
Label
The label
component lets us display read-only text.
For example, we can write:
import * as React from "react";
export default function Greeting({ }) {
return (
<frame>
<page>
<actionBar title="Default Page Title" />
<flexboxLayout justifyContent='center' >
<label>This is a Label</label>
</flexboxLayout>
</page>
</frame>
);
}
to display text on our screen.
To display formatted text, we use the formattedString
and span
components:
import * as React from "react";
import { Color } from "@nativescript/core";
export default function Greeting({ }) {
return (
<frame>
<page>
<actionBar title="Default Page Title" />
<flexboxLayout justifyContent='center' >
<label textWrap>
<formattedString>
<span>This text has a </span>
<span color={new Color("red")}>red </span>
<span>piece of text. </span>
<span fontStyle="italic">This is italic, </span>
<span fontWeight="bold">and this bit is bold.</span>
</formattedString>
</label>
</flexboxLayout>
</page>
</frame>
);
}
We put all our formatted text in the formattedString
component.
The span
have the text we want to display.
We style the text with props. The color
prop takes an object returned by the Color
function.
Conclusion
We can add HTML, images, and text to our mobile app with React NativeScript.